home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 3: Developer Tools / Linux Cubed Series 3 - Developer Tools.iso / devel / lang / lisp / guile-ii.src / guile-ii / guile-src / libguile / dynwind.c < prev    next >
Encoding:
C/C++ Source or Header  |  1995-07-04  |  3.4 KB  |  121 lines

  1. /*    Copyright (C) 1995 Free Software Foundation, Inc.
  2.  * 
  3.  * This program is free software; you can redistribute it and/or modify
  4.  * it under the terms of the GNU General Public License as published by
  5.  * the Free Software Foundation; either version 2, or (at your option)
  6.  * any later version.
  7.  * 
  8.  * This program is distributed in the hope that it will be useful,
  9.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.  * GNU General Public License for more details.
  12.  * 
  13.  * You should have received a copy of the GNU General Public License
  14.  * along with this software; see the file COPYING.  If not, write to
  15.  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  16.  *
  17.  * As a special exception, the Free Software Foundation gives permission
  18.  * for additional uses of the text contained in its release of GUILE.
  19.  *
  20.  * The exception is that, if you link the GUILE library with other files
  21.  * to produce an executable, this does not by itself cause the
  22.  * resulting executable to be covered by the GNU General Public License.
  23.  * Your use of that executable is in no way restricted on account of
  24.  * linking the GUILE library code into it.
  25.  *
  26.  * This exception does not however invalidate any other reasons why
  27.  * the executable file might be covered by the GNU General Public License.
  28.  *
  29.  * This exception applies only to the code released by the
  30.  * Free Software Foundation under the name GUILE.  If you copy
  31.  * code from other Free Software Foundation releases into a copy of
  32.  * GUILE, as the General Public License permits, the exception does
  33.  * not apply to the code that you add in this way.  To avoid misleading
  34.  * anyone as to the status of such modified files, you must delete
  35.  * this exception notice from them.
  36.  *
  37.  * If you write modifications of your own for GUILE, it is your choice
  38.  * whether to permit this exception to apply to your modifications.
  39.  * If you do not wish that, delete this exception notice.  
  40.  */
  41.  
  42.  
  43. #include <stdio.h>
  44. #include "_scm.h"
  45.  
  46.  
  47.  
  48. /* {Dynamic wind}
  49.  */
  50.  
  51.  
  52.  
  53. PROC (s_dynamic_wind, "dynamic-wind", 3, 0, 0, scm_dynamic_wind);
  54. #ifdef __STDC__
  55. SCM 
  56. scm_dynamic_wind (SCM thunk1, SCM thunk2, SCM thunk3)
  57. #else
  58. SCM 
  59. scm_dynamic_wind (thunk1, thunk2, thunk3)
  60.      SCM thunk1;
  61.      SCM thunk2;
  62.      SCM thunk3;
  63. #endif
  64. {
  65.   SCM ans;
  66.   scm_apply (thunk1, EOL, EOL);
  67.   dynwinds = scm_acons (thunk1, thunk3, dynwinds);
  68.   ans = scm_apply (thunk2, EOL, EOL);
  69.   dynwinds = CDR (dynwinds);
  70.   scm_apply (thunk3, EOL, EOL);
  71.   return ans;
  72. }
  73.  
  74. #ifdef __STDC__
  75. void 
  76. scm_dowinds (SCM to, long delta)
  77. #else
  78. void 
  79. scm_dowinds (to, delta)
  80.      SCM to;
  81.      long delta;
  82. #endif
  83. {
  84.  tail:
  85.   if (dynwinds == to);
  86.   else if (0 > delta)
  87.     {
  88.       SCM wind_key;
  89.       scm_dowinds (CDR (to), 1 + delta);
  90.       wind_key = CAR (CAR (to));
  91.       if (!(NIMP (wind_key) && SYMBOLP (wind_key)) && (wind_key != BOOL_F) && (wind_key != BOOL_T))
  92.     scm_apply (wind_key, EOL, EOL);
  93.       dynwinds = to;
  94.     }
  95.   else
  96.     {
  97.       SCM from;
  98.       SCM wind_key;
  99.       from = CDR (CAR (dynwinds));
  100.       wind_key = CAR (CAR (dynwinds));
  101.       dynwinds = CDR (dynwinds);
  102.       if (!(NIMP (wind_key) && SYMBOLP (wind_key)) && (wind_key != BOOL_F) && (wind_key != BOOL_T))
  103.     scm_apply (from, EOL, EOL);
  104.       delta--;
  105.       goto tail;        /* scm_dowinds(to, delta-1); */
  106.     }
  107. }
  108.  
  109.  
  110. #ifdef __STDC__
  111. void
  112. scm_init_dynwind (void)
  113. #else
  114. void
  115. scm_init_dynwind ()
  116. #endif
  117. {
  118. #include "dynwind.x"
  119. }
  120.  
  121.